/*
 * <<
 *  Davinci
 *  ==
 *  Copyright (C) 2016 - 2019 EDP
 *  ==
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *        http://www.apache.org/licenses/LICENSE-2.0
 *   Unless required by applicable law or agreed to in writing, software
 *   distributed under the License is distributed on an "AS IS" BASIS,
 *   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *   See the License for the specific language governing permissions and
 *   limitations under the License.
 *  >>
 *
 */

package edp.davinci.dao;

import java.util.List;

import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.Update;
import org.springframework.stereotype.Component;

import edp.davinci.model.MemDashboardWidget;

@Component
public interface MemDashboardWidgetMapper
{
    int insert(MemDashboardWidget memDashboardWidget);
    
    @Delete({"delete from mem_dashboard_widget where id = #{id}"})
    int deleteById(@Param("id") Long id);
    
    @Select({"select * from mem_dashboard_widget where id = #{id}"})
    MemDashboardWidget getById(@Param("id") Long id);
    
    @Update({"update mem_dashboard_widget", "set dashboard_id = #{dashboardId,jdbcType=BIGINT},", "widget_Id = #{widgetId,jdbcType=BIGINT},",
        "x = #{x,jdbcType=INTEGER},", "y = #{y,jdbcType=INTEGER},", "width = #{width,jdbcType=INTEGER},", "height = #{height,jdbcType=INTEGER},",
        "polling = #{polling,jdbcType=BIT},", "frequency = #{frequency,jdbcType=INTEGER},", "`config` = #{config,jdbcType=LONGVARCHAR}",
        "where id = #{id,jdbcType=BIGINT}"})
    int update(MemDashboardWidget memDashboardWidget);
    
    @Select({"select * from mem_dashboard_widget where dashboard_id = #{dashboardId}"})
    List<MemDashboardWidget> getByDashboardId(@Param("dashboardId") Long dashboardId);
    
    @Delete({"delete from mem_dashboard_widget where dashboard_id in ",
        "(SELECT d.id FROM dashboard d LEFT JOIN dashboard_portal p on d.dashboard_portal_id = p.id where p.project_id = #{projectId})"})
    int deleteByProject(@Param("projectId") Long projectId);
    
    int insertBatch(@Param("list") List<MemDashboardWidget> list);
    
    int updateBatch(List<MemDashboardWidget> list);
    
    @Delete("delete from mem_dashboard_widget where widget_Id = #{widgetId}")
    int deleteByWidget(@Param("widgetId") Long widgetId);
    
    @Delete({"DELETE mdw FROM mem_dashboard_widget mdw WHERE mdw.dashboard_id IN " + "( " + "SELECT d.id " + "FROM dashboard d "
        + "WHERE d.dashboard_portal_id = #{portalId} " + ") "})
    int deleteByPortalId(@Param("portalId") Long portalId);
    
    @Delete("delete from mem_dashboard_widget where dashboard_id = #{dashboardId}")
    int deleteByDashboardId(@Param("dashboardId") Long dashboardId);
}